<template>
  <div>
    <div>
      <div style="display: flex;justify-content: space-between">
        <div>
          <el-input placeholder="请输入员工名进行搜索，可以直接回车搜索..."
                    prefix-icon="el-icon-search"
                    clearable
                    @clear="initEmps"
                    style="width: 350px;margin-right: 10px"
                    v-model="keyword"
                    @keydown.enter.native="initEmps"
                    :disabled="showAdvanceSearchView"></el-input>
          <el-button icon="el-icon-search"
                     type="primary"
                     @click="initEmps"
                     :disabled="showAdvanceSearchView">
            搜索
          </el-button>
          <el-button type="primary"
                     @click="showAdvanceSearchView = !showAdvanceSearchView">
            <i :class="showAdvanceSearchView?'fa fa-angle-double-up':'fa fa-angle-double-down'"
               aria-hidden="true"></i>
            高级搜索
          </el-button>
        </div>
        <div>
          <el-upload :show-file-list="false"
                     :before-upload="beforeUpload"
                     :on-success="onSuccess"
                     :on-error="onError"
                     :disabled="importDataDisabled"
                     style="display: inline-flex;margin-right: 8px"
                     action="/employee/basic/import">
            <el-button :disabled="importDataDisabled"
                       type="success"
                       :icon="importDataBtnIcon">
              {{importDataBtnText}}
            </el-button>
          </el-upload>
          <el-button type="success"
                     @click="exportData"
                     icon="el-icon-download">
            导出数据
          </el-button>
          <el-button type="primary"
                     icon="el-icon-plus"
                     @click="showAddEmpView">
            添加用户
          </el-button>
        </div>
      </div>
      <transition name="slide-fade">
        <div v-show="showAdvanceSearchView"
             style="border: 1px solid #409eff;border-radius: 5px;box-sizing: border-box;padding: 5px;margin: 10px 0px;">
          <el-row>
            <el-col :span="5">
              政治面貌:
              <el-select v-model="searchValue.politicId"
                         placeholder="政治面貌"
                         size="mini"
                         style="width: 130px;">
                <el-option v-for="item in politicsstatus"
                           :key="item.id"
                           :label="item.name"
                           :value="item.id">
                </el-option>
              </el-select>
            </el-col>
            <el-col :span="4">
              民族:
              <el-select v-model="searchValue.nationId"
                         placeholder="民族"
                         size="mini"
                         style="width: 130px;">
                <el-option v-for="item in nations"
                           :key="item.id"
                           :label="item.name"
                           :value="item.id">
                </el-option>
              </el-select>
            </el-col>
            <el-col :span="4">
              职位:
              <el-select v-model="searchValue.posId"
                         placeholder="职位"
                         size="mini"
                         style="width: 130px;">
                <el-option v-for="item in positions"
                           :key="item.id"
                           :label="item.name"
                           :value="item.id">
                </el-option>
              </el-select>
            </el-col>
            <el-col :span="4">
              职称:
              <el-select v-model="searchValue.jobLevelId"
                         placeholder="职称"
                         size="mini"
                         style="width: 130px;">
                <el-option v-for="item in joblevels"
                           :key="item.id"
                           :label="item.name"
                           :value="item.id">
                </el-option>
              </el-select>
            </el-col>
            <el-col :span="7">
              聘用形式:
              <el-radio-group v-model="searchValue.engageForm">
                <el-radio label="劳动合同">劳动合同</el-radio>
                <el-radio label="劳务合同">劳务合同</el-radio>
              </el-radio-group>
            </el-col>
          </el-row>
          <el-row style="margin-top: 10px">
            <el-col :span="5">
              所属部门:
              <el-popover placement="right"
                          title="请选择部门"
                          width="200"
                          trigger="manual"
                          v-model="popVisible2">
                <el-tree default-expand-all
                         :data="allDeps"
                         :props="defaultProps"
                         @node-click="searvhViewHandleNodeClick"></el-tree>
                <div slot="reference"
                     style="width: 130px;display: inline-flex;font-size: 13px;border: 1px solid #dedede;height: 26px;border-radius: 5px;cursor: pointer;align-items: center;padding-left: 8px;box-sizing: border-box;margin-left: 3px"
                     @click="showDepView2">{{inputDepName}}
                </div>
              </el-popover>
            </el-col>
            <el-col :span="10">
              入职日期:
              <el-date-picker v-model="searchValue.beginDateScope"
                              type="daterange"
                              size="mini"
                              unlink-panels
                              value-format="yyyy-MM-dd"
                              range-separator="至"
                              start-placeholder="开始日期"
                              end-placeholder="结束日期">
              </el-date-picker>
            </el-col>
            <el-col :span="5"
                    :offset="4">
              <el-button size="mini">取消</el-button>
              <el-button size="mini"
                         icon="el-icon-search"
                         type="primary"
                         @click="initEmps('advanced')">搜索</el-button>
            </el-col>
          </el-row>
        </div>
      </transition>
    </div>
    <div style="margin-top: 10px">
      <el-table :data="emps"
                stripe
                border
                v-loading="loading"
                element-loading-text="正在加载..."
                element-loading-spinner="el-icon-loading"
                element-loading-background="rgba(0, 0, 0, 0.8)"
                style="width: 100%">
        <el-table-column type="selection"
                         width="55">
        </el-table-column>
        <el-table-column prop="name"
                         fixed
                         align="left"
                         label="姓名"
                         width="90">
        </el-table-column>
        <el-table-column prop="workID"
                         label="工号"
                         align="left"
                         width="85">
        </el-table-column>
        <el-table-column prop="gender"
                         label="性别"
                         align="left"
                         width="85">
        </el-table-column>
        <el-table-column prop="birthday"
                         width="95"
                         align="left"
                         label="出生日期">
        </el-table-column>
        <el-table-column prop="idCard"
                         width="150"
                         align="left"
                         label="身份证号码">
        </el-table-column>
        <el-table-column prop="wedlock"
                         width="70"
                         label="婚姻状况">
        </el-table-column>
        <el-table-column prop="nation.name"
                         width="50"
                         label="民族">
        </el-table-column>
        <el-table-column prop="nativePlace"
                         width="80"
                         label="籍贯">
        </el-table-column>
        <el-table-column prop="politicsstatus.name"
                         label="政治面貌">
        </el-table-column>
        <el-table-column prop="email"
                         width="180"
                         align="left"
                         label="电子邮件">
        </el-table-column>
        <el-table-column prop="phone"
                         width="100"
                         align="left"
                         label="电话号码">
        </el-table-column>
        <el-table-column prop="address"
                         width="220"
                         align="left"
                         label="联系地址">
        </el-table-column>
        <el-table-column prop="department.name"
                         width="100"
                         align="left"
                         label="所属部门">
        </el-table-column>
        <el-table-column prop="position.name"
                         width="100"
                         label="职位">
        </el-table-column>
        <el-table-column prop="jobLevel.name"
                         width="100"
                         label="职称">
        </el-table-column>
        <el-table-column prop="engageForm"
                         width="100"
                         align="left"
                         label="聘用形式">
        </el-table-column>
        <el-table-column prop="tiptopDegree"
                         width="80"
                         align="left"
                         label="最高学历">
        </el-table-column>
        <el-table-column prop="specialty"
                         width="150"
                         align="left"
                         label="专业">
        </el-table-column>
        <el-table-column prop="school"
                         width="150"
                         align="left"
                         label="毕业院校">
        </el-table-column>
        <el-table-column prop="beginDate"
                         width="95"
                         align="left"
                         label="入职日期">
        </el-table-column>
        <el-table-column prop="conversionTime"
                         width="95"
                         align="left"
                         label="转正日期">
        </el-table-column>
        <el-table-column prop="beginContract"
                         width="95"
                         align="left"
                         label="合同起始日期">
        </el-table-column>
        <el-table-column prop="endContract"
                         width="95"
                         align="left"
                         label="合同截止日期">
        </el-table-column>
        <el-table-column width="100"
                         align="left"
                         label="合同期限">
          <template slot-scope="scope">
            <el-tag>{{scope.row.contractTerm}}</el-tag>
            年
          </template>
        </el-table-column>
        <el-table-column fixed="right"
                         width="200"
                         label="操作">
          <template slot-scope="scope">
            <el-button @click="showEditEmpView(scope.row)"
                       style="padding: 3px"
                       size="mini">编辑</el-button>
            <el-button style="padding: 3px"
                       size="mini"
                       type="primary">查看高级资料</el-button>
            <el-button @click="deleteEmp(scope.row)"
                       style="padding: 3px"
                       size="mini"
                       type="danger">删除
            </el-button>
          </template>
        </el-table-column>
      </el-table>
      <div style="display: flex;justify-content: flex-end">
        <el-pagination background
                       @current-change="currentChange"
                       @size-change="sizeChange"
                       layout="sizes, prev, pager, next, jumper, ->, total, slot"
                       :total="total">
        </el-pagination>
      </div>
    </div>
    <el-dialog :title="title"
               :visible.sync="dialogVisible"
               width="80%">
      <div>
        <el-form :model="emp"
                 :rules="rules"
                 ref="empForm">
          <el-row>
            <el-col :span="6">
              <el-form-item label="姓名:"
                            prop="name">
                <el-input size="mini"
                          style="width: 150px"
                          prefix-icon="el-icon-edit"
                          v-model="emp.name"
                          placeholder="请输入员工姓名"></el-input>
              </el-form-item>
            </el-col>
            <el-col :span="5">
              <el-form-item label="性别:"
                            prop="gender">
                <el-radio-group v-model="emp.gender">
                  <el-radio label="男">男</el-radio>
                  <el-radio label="女">女</el-radio>
                </el-radio-group>
              </el-form-item>
            </el-col>
            <el-col :span="6">
              <el-form-item label="出生日期:"
                            prop="birthday">
                <el-date-picker v-model="emp.birthday"
                                size="mini"
                                type="date"
                                value-format="yyyy-MM-dd"
                                style="width: 150px;"
                                placeholder="出生日期">
                </el-date-picker>
              </el-form-item>
            </el-col>
            <el-col :span="7">
              <el-form-item label="政治面貌:"
                            prop="politicId">
                <el-select v-model="emp.politicId"
                           placeholder="政治面貌"
                           size="mini"
                           style="width: 200px;">
                  <el-option v-for="item in politicsstatus"
                             :key="item.id"
                             :label="item.name"
                             :value="item.id">
                  </el-option>
                </el-select>
              </el-form-item>
            </el-col>
          </el-row>
          <el-row>
            <el-col :span="6">
              <el-form-item label="民族:"
                            prop="nationId">
                <el-select v-model="emp.nationId"
                           placeholder="民族"
                           size="mini"
                           style="width: 150px;">
                  <el-option v-for="item in nations"
                             :key="item.id"
                             :label="item.name"
                             :value="item.id">
                  </el-option>
                </el-select>
              </el-form-item>
            </el-col>
            <el-col :span="5">
              <el-form-item label="籍贯:"
                            prop="nativePlace">
                <el-input size="mini"
                          style="width: 120px"
                          prefix-icon="el-icon-edit"
                          v-model="emp.nativePlace"
                          placeholder="请输入籍贯"></el-input>
              </el-form-item>
            </el-col>
            <el-col :span="6">
              <el-form-item label="电子邮箱:"
                            prop="email">
                <el-input size="mini"
                          style="width: 150px"
                          prefix-icon="el-icon-message"
                          v-model="emp.email"
                          placeholder="请输入电子邮箱"></el-input>
              </el-form-item>
            </el-col>
            <el-col :span="7">
              <el-form-item label="联系地址:"
                            prop="address">
                <el-input size="mini"
                          style="width: 200px"
                          prefix-icon="el-icon-edit"
                          v-model="emp.address"
                          placeholder="请输入联系地址"></el-input>
              </el-form-item>
            </el-col>
          </el-row>
          <el-row>
            <el-col :span="6">
              <el-form-item label="职位:"
                            prop="posId">
                <el-select v-model="emp.posId"
                           placeholder="职位"
                           size="mini"
                           style="width: 150px;">
                  <el-option v-for="item in positions"
                             :key="item.id"
                             :label="item.name"
                             :value="item.id">
                  </el-option>
                </el-select>
              </el-form-item>
            </el-col>
            <el-col :span="5">
              <el-form-item label="职称:"
                            prop="jobLevelId">
                <el-select v-model="emp.jobLevelId"
                           placeholder="职称"
                           size="mini"
                           style="width: 150px;">
                  <el-option v-for="item in joblevels"
                             :key="item.id"
                             :label="item.name"
                             :value="item.id">
                  </el-option>
                </el-select>
              </el-form-item>
            </el-col>
            <el-col :span="6">
              <el-form-item label="所属部门:"
                            prop="departmentId">
                <el-popover placement="right"
                            title="请选择部门"
                            width="200"
                            trigger="manual"
                            v-model="popVisible">
                  <el-tree default-expand-all
                           :data="allDeps"
                           :props="defaultProps"
                           @node-click="handleNodeClick"></el-tree>
                  <div slot="reference"
                       style="width: 150px;display: inline-flex;font-size: 13px;border: 1px solid #dedede;height: 26px;border-radius: 5px;cursor: pointer;align-items: center;padding-left: 8px;box-sizing: border-box"
                       @click="showDepView">{{inputDepName}}
                  </div>
                </el-popover>
              </el-form-item>
            </el-col>
            <el-col :span="7">
              <el-form-item label="电话号码:"
                            prop="phone">
                <el-input size="mini"
                          style="width: 200px"
                          prefix-icon="el-icon-phone"
                          v-model="emp.phone"
                          placeholder="电话号码"></el-input>
              </el-form-item>
            </el-col>
          </el-row>
          <el-row>
            <el-col :span="6">
              <el-form-item label="工号:"
                            prop="workID">
                <el-input size="mini"
                          style="width: 150px"
                          prefix-icon="el-icon-edit"
                          v-model="emp.workID"
                          placeholder="工号"
                          disabled></el-input>
              </el-form-item>
            </el-col>
            <el-col :span="5">
              <el-form-item label="学历:"
                            prop="tiptopDegree">
                <el-select v-model="emp.tiptopDegree"
                           placeholder="学历"
                           size="mini"
                           style="width: 150px;">
                  <el-option v-for="item in tiptopDegrees"
                             :key="item"
                             :label="item"
                             :value="item">
                  </el-option>
                </el-select>
              </el-form-item>
            </el-col>
            <el-col :span="6">
              <el-form-item label="毕业院校:"
                            prop="school">
                <el-input size="mini"
                          style="width: 150px"
                          prefix-icon="el-icon-edit"
                          v-model="emp.school"
                          placeholder="毕业院校名称"></el-input>
              </el-form-item>
            </el-col>
            <el-col :span="7">
              <el-form-item label="专业名称:"
                            prop="specialty">
                <el-input size="mini"
                          style="width: 200px"
                          prefix-icon="el-icon-edit"
                          v-model="emp.specialty"
                          placeholder="请输入专业名称"></el-input>
              </el-form-item>
            </el-col>
          </el-row>
          <el-row>
            <el-col :span="6">
              <el-form-item label="入职日期:"
                            prop="beginDate">
                <el-date-picker v-model="emp.beginDate"
                                size="mini"
                                type="date"
                                value-format="yyyy-MM-dd"
                                style="width: 130px;"
                                placeholder="入职日期">
                </el-date-picker>
              </el-form-item>
            </el-col>
            <el-col :span="6">
              <el-form-item label="转正日期:"
                            prop="conversionTime">
                <el-date-picker v-model="emp.conversionTime"
                                size="mini"
                                type="date"
                                value-format="yyyy-MM-dd"
                                style="width: 130px;"
                                placeholder="转正日期">
                </el-date-picker>
              </el-form-item>
            </el-col>
            <el-col :span="6">
              <el-form-item label="合同起始日期:"
                            prop="beginContract">
                <el-date-picker v-model="emp.beginContract"
                                size="mini"
                                type="date"
                                value-format="yyyy-MM-dd"
                                style="width: 130px;"
                                placeholder="合同起始日期">
                </el-date-picker>
              </el-form-item>
            </el-col>
            <el-col :span="6">
              <el-form-item label="合同终止日期:"
                            prop="endContract">
                <el-date-picker v-model="emp.endContract"
                                size="mini"
                                type="date"
                                value-format="yyyy-MM-dd"
                                style="width: 150px;"
                                placeholder="合同终止日期">
                </el-date-picker>
              </el-form-item>
            </el-col>
          </el-row>
          <el-row>
            <el-col :span="8">
              <el-form-item label="身份证号码:"
                            prop="idCard">
                <el-input size="mini"
                          style="width: 180px"
                          prefix-icon="el-icon-edit"
                          v-model="emp.idCard"
                          placeholder="请输入身份证号码"></el-input>
              </el-form-item>
            </el-col>
            <el-col :span="8">
              <el-form-item label="聘用形式:"
                            prop="engageForm">
                <el-radio-group v-model="emp.engageForm">
                  <el-radio label="劳动合同">劳动合同</el-radio>
                  <el-radio label="劳务合同">劳务合同</el-radio>
                </el-radio-group>
              </el-form-item>
            </el-col>
            <el-col :span="8">
              <el-form-item label="婚姻状况:"
                            prop="wedlock">
                <el-radio-group v-model="emp.wedlock">
                  <el-radio label="已婚">已婚</el-radio>
                  <el-radio label="未婚">未婚</el-radio>
                  <el-radio label="离异">离异</el-radio>
                </el-radio-group>
              </el-form-item>
            </el-col>
          </el-row>
        </el-form>
      </div>
      <span slot="footer"
            class="dialog-footer">
        <el-button @click="dialogVisible = false">取 消</el-button>
        <el-button type="primary"
                   @click="doAddEmp()">确 定</el-button>
      </span>
    </el-dialog>
  </div>
</template>

<script>
export default {
  name: 'EmpBasic',

  data() {
    return {
      searchValue: {
        politicId: null,
        nationId: null,
        jobLevelId: null,
        posId: null,
        engageForm: null,
        departmentId: null,
        beginDateScope: null,
      },
      title: '',
      importDataBtnText: '导入数据',
      importDataBtnIcon: 'el-icon-upload2',
      importDataDisabled: false,
      showAdvanceSearchView: false,
      allDeps: [],
      emps: [],
      loading: false,
      popVisible: false,
      popVisible2: false,
      dialogVisible: false,
      total: 0,
      page: 1,
      keyword: '',
      size: 10,
      nations: [],
      joblevels: [],
      politicsstatus: [],
      positions: [],
      tiptopDegrees: [
        '本科',
        '大专',
        '硕士',
        '博士',
        '高中',
        '初中',
        '小学',
        '其他',
      ],
      options: [
        {
          value: '选项1',
          label: '黄金糕',
        },
        {
          value: '选项2',
          label: '双皮奶',
        },
        {
          value: '选项3',
          label: '蚵仔煎',
        },
        {
          value: '选项4',
          label: '龙须面',
        },
        {
          value: '选项5',
          label: '北京烤鸭',
        },
      ],
      inputDepName: '所属部门',
      emp: {
        name: 'javaboy',
        gender: '男',
        birthday: '1989-12-31',
        idCard: '610122199001011256',
        wedlock: '已婚',
        nationId: 1,
        nativePlace: '陕西',
        politicId: 13,
        email: 'laowang@qq.com',
        phone: '18565558897',
        address: '深圳市南山区',
        departmentId: null,
        jobLevelId: 9,
        posId: 29,
        engageForm: '劳务合同',
        tiptopDegree: '本科',
        specialty: '信息管理与信息系统',
        school: '深圳大学',
        beginDate: '2017-12-31',
        workState: '在职',
        workID: '00000057',
        contractTerm: 2,
        conversionTime: '2018-03-31',
        notworkDate: null,
        beginContract: '2017-12-31',
        endContract: '2019-12-31',
        workAge: null,
      },
      defaultProps: {
        children: 'children',
        label: 'name',
      },
      rules: {
        name: [{ required: true, message: '请输入用户名', trigger: 'blur' }],
        gender: [{ required: true, message: '请输入性别', trigger: 'blur' }],
        birthday: [
          { required: true, message: '请输入出生日期', trigger: 'blur' },
        ],
        idCard: [
          { required: true, message: '请输入身份证号码', trigger: 'blur' },
          {
            pattern:
              /(^[1-9]\d{5}(18|19|([23]\d))\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\d{3}[0-9Xx]$)|(^[1-9]\d{5}\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\d{2}$)/,
            message: '身份证号码格式不正确',
            trigger: 'blur',
          },
        ],
        wedlock: [
          { required: true, message: '请输入婚姻状况', trigger: 'blur' },
        ],
        nationId: [{ required: true, message: '请输入您组', trigger: 'blur' }],
        nativePlace: [
          { required: true, message: '请输入籍贯', trigger: 'blur' },
        ],
        politicId: [
          { required: true, message: '请输入政治面貌', trigger: 'blur' },
        ],
        email: [
          { required: true, message: '请输入邮箱地址', trigger: 'blur' },
          {
            type: 'email',
            message: '邮箱格式不正确',
            trigger: 'blur',
          },
        ],
        phone: [{ required: true, message: '请输入电话号码', trigger: 'blur' }],
        address: [
          { required: true, message: '请输入员工地址', trigger: 'blur' },
        ],
        departmentId: [
          { required: true, message: '请输入部门名称', trigger: 'blur' },
        ],
        jobLevelId: [
          { required: true, message: '请输入职称', trigger: 'blur' },
        ],
        posId: [{ required: true, message: '请输入职位', trigger: 'blur' }],
        engageForm: [
          { required: true, message: '请输入聘用形式', trigger: 'blur' },
        ],
        tiptopDegree: [
          { required: true, message: '请输入学历', trigger: 'blur' },
        ],
        specialty: [{ required: true, message: '请输入专业', trigger: 'blur' }],
        school: [
          { required: true, message: '请输入毕业院校', trigger: 'blur' },
        ],
        beginDate: [
          { required: true, message: '请输入入职日期', trigger: 'blur' },
        ],
        workState: [
          { required: true, message: '请输入工作状态', trigger: 'blur' },
        ],
        workID: [{ required: true, message: '请输入工号', trigger: 'blur' }],
        contractTerm: [
          { required: true, message: '请输入合同期限', trigger: 'blur' },
        ],
        conversionTime: [
          { required: true, message: '请输入转正日期', trigger: 'blur' },
        ],
        notworkDate: [
          { required: true, message: '请输入离职日期', trigger: 'blur' },
        ],
        beginContract: [
          { required: true, message: '请输入合同起始日期', trigger: 'blur' },
        ],
        endContract: [
          { required: true, message: '请输入合同结束日期', trigger: 'blur' },
        ],
        workAge: [{ required: true, message: '请输入工龄', trigger: 'blur' }],
      },
    }
  },
  mounted() {
    this.initEmps()
    this.initData()
    this.initPositions()
  },
  methods: {
    searvhViewHandleNodeClick(data) {
      this.inputDepName = data.name
      this.searchValue.departmentId = data.id
      this.popVisible2 = !this.popVisible2
    },
    onError(err, file, fileList) {
      this.importDataBtnText = '导入数据'
      this.importDataBtnIcon = 'el-icon-upload2'
      this.importDataDisabled = false
    },
    onSuccess(response, file, fileList) {
      this.importDataBtnText = '导入数据'
      this.importDataBtnIcon = 'el-icon-upload2'
      this.importDataDisabled = false
      this.initEmps()
    },
    beforeUpload() {
      this.importDataBtnText = '正在导入'
      this.importDataBtnIcon = 'el-icon-loading'
      this.importDataDisabled = true
    },
    exportData() {
      window.open('/employee/basic/export', '_parent')
    },
    emptyEmp() {
      this.emp = {
        name: '',
        gender: '',
        birthday: '',
        idCard: '',
        wedlock: '',
        nationId: 1,
        nativePlace: '',
        politicId: 13,
        email: '',
        phone: '',
        address: '',
        departmentId: null,
        jobLevelId: 9,
        posId: 29,
        engageForm: '',
        tiptopDegree: '',
        specialty: '',
        school: '',
        beginDate: '',
        workID: '',
        contractTerm: 2,
        conversionTime: '',
        notworkDate: null,
        beginContract: '',
        endContract: '',
        workAge: null,
      }
      this.inputDepName = ''
    },
    showEditEmpView(data) {
      this.initPositions()
      this.title = '编辑员工信息'
      this.emp = data
      this.inputDepName = data.department.name
      this.dialogVisible = true
    },
    deleteEmp(data) {
      this.$confirm(
        '此操作将永久删除【' + data.name + '】, 是否继续?',
        '提示',
        {
          confirmButtonText: '确定',
          cancelButtonText: '取消',
          type: 'warning',
        }
      )
        .then(() => {
          this.deleteRequest('/employee/basic/' + data.id).then((resp) => {
            if (resp) {
              this.initEmps()
            }
          })
        })
        .catch(() => {
          this.$message({
            type: 'info',
            message: '已取消删除',
          })
        })
    },
    doAddEmp() {
      if (this.emp.id) {
        this.$refs['empForm'].validate((valid) => {
          if (valid) {
            this.putRequest('/employee/basic/', this.emp).then((resp) => {
              if (resp) {
                this.dialogVisible = false
                this.initEmps()
              }
            })
          }
        })
      } else {
        this.$refs['empForm'].validate((valid) => {
          if (valid) {
            this.postRequest('/employee/basic/', this.emp).then((resp) => {
              if (resp) {
                this.dialogVisible = false
                this.initEmps()
              }
            })
          }
        })
      }
    },
    handleNodeClick(data) {
      this.inputDepName = data.name
      this.emp.departmentId = data.id
      this.popVisible = !this.popVisible
    },
    showDepView() {
      this.popVisible = !this.popVisible
    },
    showDepView2() {
      this.popVisible2 = !this.popVisible2
    },
    initPositions() {
      this.getRequest('/employee/basic/positions').then((resp) => {
        if (resp) {
          this.positions = resp
        }
      })
    },
    getMaxWordID() {
      this.getRequest('/employee/basic/maxWorkID').then((resp) => {
        if (resp) {
          this.emp.workID = resp.obj
        }
      })
    },
    initData() {
      if (!window.sessionStorage.getItem('nations')) {
        this.getRequest('/employee/basic/nations').then((resp) => {
          if (resp) {
            this.nations = resp
            window.sessionStorage.setItem('nations', JSON.stringify(resp))
          }
        })
      } else {
        this.nations = JSON.parse(window.sessionStorage.getItem('nations'))
      }
      if (!window.sessionStorage.getItem('joblevels')) {
        this.getRequest('/employee/basic/joblevels').then((resp) => {
          if (resp) {
            this.joblevels = resp
            window.sessionStorage.setItem('joblevels', JSON.stringify(resp))
          }
        })
      } else {
        this.joblevels = JSON.parse(window.sessionStorage.getItem('joblevels'))
      }
      if (!window.sessionStorage.getItem('politicsstatus')) {
        this.getRequest('/employee/basic/politicsstatus').then((resp) => {
          if (resp) {
            this.politicsstatus = resp
            window.sessionStorage.setItem(
              'politicsstatus',
              JSON.stringify(resp)
            )
          }
        })
      } else {
        this.politicsstatus = JSON.parse(
          window.sessionStorage.getItem('politicsstatus')
        )
      }
      if (!window.sessionStorage.getItem('deps')) {
        this.getRequest('/employee/basic/deps').then((resp) => {
          if (resp) {
            this.allDeps = resp
            window.sessionStorage.setItem('deps', JSON.stringify(resp))
          }
        })
      } else {
        this.allDeps = JSON.parse(window.sessionStorage.getItem('deps'))
      }
    },
    sizeChange(currentSize) {
      this.size = currentSize
      this.initEmps()
    },
    currentChange(currentPage) {
      this.page = currentPage
      this.initEmps('advanced')
    },
    showAddEmpView() {
      this.emptyEmp()
      this.title = '添加员工'
      this.getMaxWordID()
      this.dialogVisible = true
    },
    initEmps(type) {
      this.loading = true
      let url = '/employee/basic/?page=' + this.page + '&size=' + this.size
      if (type && type == 'advanced') {
        if (this.searchValue.politicId) {
          url += '&politicId=' + this.searchValue.politicId
        }
        if (this.searchValue.nationId) {
          url += '&nationId=' + this.searchValue.nationId
        }
        if (this.searchValue.jobLevelId) {
          url += '&jobLevelId=' + this.searchValue.jobLevelId
        }
        if (this.searchValue.posId) {
          url += '&posId=' + this.searchValue.posId
        }
        if (this.searchValue.engageForm) {
          url += '&engageForm=' + this.searchValue.engageForm
        }
        if (this.searchValue.departmentId) {
          url += '&departmentId=' + this.searchValue.departmentId
        }
        if (this.searchValue.beginDateScope) {
          url += '&beginDateScope=' + this.searchValue.beginDateScope
        }
      } else {
        url += '&name=' + this.keyword
      }
      this.getRequest(url).then((resp) => {
        this.loading = false
        if (resp) {
          this.emps = resp.data
          console.log('嘻嘻哈哈' + this.emps)
          this.total = resp.total
        }
      })
    },
  },
}
</script>

<style>
/* 可以设置不同的进入和离开动画 */
/* 设置持续时间和动画函数 */
.slide-fade-enter-active {
  transition: all 0.8s ease;
}

.slide-fade-leave-active {
  transition: all 0.8s cubic-bezier(1, 0.5, 0.8, 1);
}

.slide-fade-enter, .slide-fade-leave-to
        /* .slide-fade-leave-active for below version 2.1.8 */ {
  transform: translateX(10px);
  opacity: 0;
}
</style>